package com.example.libary.entity;

import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableLogic;
import com.baomidou.mybatisplus.annotation.TableName;
import lombok.Data;

import java.math.BigDecimal;
import java.time.LocalDate;
import java.time.LocalDateTime;

/**
 * 图书实体类
 */
@Data
@TableName("book")
public class Book {
    
    /**
     * 图书ID
     */
    @TableId(value = "id", type = IdType.AUTO)
    private Long id;
    
    /**
     * 图书名称
     */
    private String name;
    
    /**
     * ISBN编号
     */
    private String isbn;
    
    /**
     * 作者
     */
    private String author;
    
    /**
     * 出版社
     */
    private String publisher;
    
    /**
     * 出版日期
     */
    private LocalDate publishDate;
    
    /**
     * 分类ID
     */
    private Long categoryId;
    
    /**
     * 分类名称（非数据库字段）
     */
    @TableField(exist = false)
    private String categoryName;
    
    /**
     * 价格
     */
    private BigDecimal price;
    
    /**
     * 图书描述
     */
    private String description;
    
    /**
     * 封面图片
     */
    private String cover;
    
    /**
     * 馆藏位置
     */
    private String location;
    
    /**
     * 状态（0可借 1已借出 2维修中 3已下架）
     */
    private String status;
    
    /**
     * 总数量
     */
    private Integer total;
    
    /**
     * 可借数量
     */
    private Integer available;
    
    /**
     * 是否删除（0否 1是）
     */
    @TableLogic
    private Integer deleted;
    
    /**
     * 创建时间
     */
    private LocalDateTime createTime;
    
    /**
     * 更新时间
     */
    private LocalDateTime updateTime;
} 